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[57] ABSTRACT 

A multi-processor, multi-bus system comprises a host 
processor and a cluster controller coupled to a first type 
of bus; a local processor coupled to a second type of 
bus; and bus interface circuits coupled to the first and 
second bus types for selectively enabling the second bus 
to be coupled to the host processor, and for selectively 
enabling the first bus to be coupled to the local proces- 
sor. Both bus types are asynchronous. Each bus inter- 
face circuit comprises a first-in-first-out (FIFO) regis- 
ter, interrupt logic, and transmitter/receiver logic. The 
pair of bus interface circuits together provide dual sim- 
plex data transfer between the local processor and the 
cluster controller which is directed by a parallel data 
ling (PDL) protocol. The protocol utilizes a 16-bit wide 
control word. The most significant bit 15, referred to as 
the command bit, is a "one" whenever bits 0-7 contain 
a command byte, while the command bit is "zero" 
whenever bits 0-7 contain a data byte. A logical unit 
number specified in bits 8-14 indicates to which of 128 
possible logical devices the information transfer is des- 
tined. 

8 Claims, 6 Drawing Sheets 
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many different vendors worldwide. Much of this equip- 

MULTI-PROCESSOR, MULTI-BUS SYSTEM WITH ment cannot be connected to the IBM Multibus. For 

BUS INTERFACE COMPRISING FIFO R EGISTE R example, at the present time the IBM 3274 controller 

STOCKS FOR RECEIVING AND TRANSMITTING does not support many types of printers and data stor- 

DATA AND CONTROL INFORMATION 5 ag e devices. It currently supports only dot matrix and 

line printers. Thus, it would be very desirable if there 

BACKGROUND OF THE INVENTION wcre a way to connect new varieties of peripheral 

1. Field of the Invention equipment to IBM 3274 controllers operating on the 
This invention relates generally to the area of digital IBM Multibus. 

data processing systems and, in particular, to the inter- 10 It would be of significant economic benefit to offer 
facing of two different asynchronous bus-based com- the installed base of IBM and IBM-compatible 3270 
puter systems. systems the capability of running UNIX-based applica- 

2. Description of the Related Art tion software and of benefiting from the enhanced fea- 
As is well known, there exist many diverse types of tures of recent 32-bit, high-speed processors and periph- 

data processing systems. These different computer sys- 15 eral equipment, such as laser printers, 
terns provide many different functions and have many It would also be highly desirable for users of UNIX- 
different characteristics. For any given type of data based data processing systems to have the ability to 
processing system, there are certain advantages and perform IBM 3270 System functions from the UNIX- 
certain disadvantages in comparison with other types of based system terminals. Such functions include many 
data processing systems. 20 valuabJe software applications which are resident in the 
A first well-known type of computer system, com- 32 70 host computer but which are not available in 
monly referred to as an IBM 3270 System, has found UNIX-based systems 

wide-spread commercial use in applications such as data Thus a circuit for interfacing between an IBM 3270 

entry, word processing, transacUon-handling, data com- system and a VME system is required to achieve the 

^f^^^^^ ^^^f 1 ™ 25 above-described functionality. More specifically a cir- 

^Fn^^ m ^ ^ ^ ° f cuit for * tcrfacin * *e asynchronous IBM Multibus and 

T^S ^rrnf , . ,■♦ the asynchronous VME bus is required. 

Typically, an IBM 3270 System comprises a plurality A , _r • ^t* 

of IBM 3270 terminals coupled to an IBM host proc J , ^ 0Wn P nor "* ^ for mU *^ n *. tw ?. 
sor by means of an IBM 3274 controller. Both the host 30 f n j Pressing systems operated by locking the 
processor and the controller are coupled to a system bus lw0 dl * ereflt system buscs together. Whenever one 
known as an IBM Multibus. The structure and function- ptfnbus was in use, .operations on the other system 
ality of the IBM Multibus conform to a uniquely de- bus had to be halted until the first system bus was again 
fined bus specification with respect to a wide variety of ^ Thk had a significantly adverse effect on the oner- 
ous parameters such as the number and width of chan- 35 ation of 001)1 computer systems. There is thus a signifi- 
nels, bus timing, parity, etc. cant need for an interface between two different asyn- 
In the aforementioned IBM 3270 System, the IBM chronous system buses having the features described 
3270 terminals are coupled to the IBM 3274 controller above* in which each system bus can operate indepen- 
by means of two-conductor, twisted-pair coaxial cables dently of the other. 

referred to as RG62 cables. As there is a very large 40 SUMMARY OF THE INVENTION 
quantity of IBM 3270 Systems installed throughout the 

world, there is also a very large quantity of IBM 3270 The present invention pertains to a multi-processor, 

terminals. Correspondingly, there is also a very large multi-bus system which utilizes a pair of bus interface 

investment in installed coaxial cable coupling such IBM circuits between two different computer systems having 

3270 terminals to their respective IBM 3274 controllers. 45 first and second bus types to enable users of either com- 

The current rate for installation of RG62 cabling is P uter system to access either system. Each bus interface 

approximately $ 10-25 per linear foot circuit comprises a first-in-first-out (FIFO) register 

It would be highly desirable to extend the useful life stack, interrupt logic, and transmitter/receiver logic, 

of the expensive investment in IBM 3270 System equip- The pair of bus interface circuits provides dual simplex 

ment and cable installation by giving the IBM 3270 50 data and control transfer between the two buses. 

System additional up-to-date functionality. New func- The data and command transfer between processors 

tionality is currently provided, for example, by data in the system is accomplished by a protocol which uti- 

processing systems operating under the UNIX operat- li«s a fixed 16-bit wide format control word. The most 

ing system commercially available from AT&T Infor- significant bit 15, referred to as a command bit, is a 

mation Systems, Inc. Such data processing systems are 55 "one" whenever bits 0-7 contain a command byte, 

widely available. while the command bit is "zero" whenever bits 0-7 

The UNIX operating system supports improvements contain a data byte. A logical unit number specified in 
in development software, application software, and bits 8-14 indicates to which of 128 possible logical de- 
distributed data processing software which are not vices the information transfer is destined to go. 
available using the IBM 3270 System alone. In addition, 60 Thus it is an object of the present invention to pro- 
certain commercially available processors operating vide a new and improved bus interface circuit for cou- 
under the UNIX operating systems represent the lead- pling two computer systems having different types of 
ing edge in processor versatility and throughput. system buses which enables users on either computer 

Many UNIX-based computer systems utilize a VME system to run programs on either computer system, 

system bus. The VME bus is a widely used standard 65 It is also an object of the present invention to provide 

bus. A large number of processors and associated mem- a new and improved bus interface circuit for coupling 

ory and peripheral equipment are compatible with the two computer systems having different types of system 

VME bus, and they are commercially available from buses which enables users on either computer system to 
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utilize processors) and/or peripheral equipment cou- 
pled to either computer system. 

It is a further object of the present invention to pro- 
vide a new and improved bus interface circuit for cou- 
pling two computer systems having different types of 5 
system buses which enables users on either computer 
system to obtain the above-mentioned results without 
disrupting the operation of either computer system. 



buses 12 and 14 independent and will be described in 
greater detail in succeeding paragraphs. 

It should be apparent to those skilled in the art that 
while peripheral units 21-25 have been shown con- 
nected through controller 18 to bus 12, and peripheral 
units 31-35 have been shown connected to bus 14, these 
elements are not essential to the present invention. Situ- 
ations may arise where two types of processors are 
required to be joined, but no peripheral units are neces- 



These and other objects of this invention will become 
apparent to those skilled in the art upon consideration of 10 sary on one bus or the other. Furthermore, while five 

peripheral units have been shown attached to each bus 
in FIG. 1 for illustrative purposes, more or less periph- 
eral units are possible. 



the accompanying specification, claims, and drawings. 
BRIEF DESCRIPTION OF THE DRAWINGS 
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Referring specifically to FIG. 2, a more detailed 
block diagram of bus interfaces 40 and 50 is shown. Bus 
interface 40 includes interrupt and control logic 46 and 
a FIFO register stack 55. Associated with FIFO regis- 
ter stack 55 is a status register 59. Bus interface 50 in- 
cludes interrupt and control logic 48 and a FIFO regis- 
20 ter stack 60. Associated with FIFO register stack 60 is 
a status register 61. A dual simplex path for data and 
control information is achieved by interconnecting 
buses 42 and 44. 
FIFO register stack 55 receives data from bus 14 via 
25 data bus 57, drivers 88, data and control bus 42, and line 
receivers 56 and transfers it to bus 12 FIFO register 
stack 55 receives control information from bus 14 via 
address and control bus 54, interrupt and control logic 
48, control bus 42, drivers 88, data and control bus 42, 
30 and line receivers 56. FIFO register stack 55 and drivers 
98 also receive control information over control bus 41 
via line receivers 56, bus 46, and interrupt and control 
logic 46. Similarly, FIFO register stack 60 receives data 
from bus 12 via data bus 53, drivers 98, data and control 
bus 44, and line receivers 86 and transfers it to bus 14. 
FIFO register stack 60 receives control information 
from bus 12 via address and control bus 52, interrupt 
and control logic 46, control bus 41, drivers 98, data and 
control bus 44, and line receivers 86. FIFO register 



35 



Referring to the drawings, wherein like characters 
indicate like parts throughout the figures: 

FIG. 1 is a block diagram of a multi-processor, multi- 
bus system having an interface embodying the present 
invention; 

FIG. 2 is a more detailed block diagram of the bus A 
and bus B interfaces illustrated in FIG. 1; 

FIG. 3 is a detailed block diagram of the bus A inter- 
face illustrated in FIG. 1; 

FIG. 4 is a detailed block diagram of the bus B inter- 
face illustrated in FIG. 1; 

FIG. 5 is an illustration of the format of a 16-bit con- 
trol word used in the present invention; and 

FIG. 6 is an illustration of a multi-byte data transfer 
block used in the present invention. 

DESCRIPTION OF THE PREFERRED 
EMBODIMENTS 

Referring specifically to FIG. 1, a system, generally 
labeled 10, is shown. System 10 has two asynchronous 
buses 12 and 14. Bus 12 has coupled to it a processor 16 
and a device controller 18. A series of peripheral units 
21-25 are coupled to and controlled by device control- 
ler 18. Peripheral units 21-25 may be work stations, 
printers, and the like. 

In a preferred embodiment of the present invention, 
processor 16 is a standard Intel processor, controller 18 40 stack 60 and drivers 88 also receive control information 
is a specialized controller for IBM coax-A devices, and over control bus 42 via line receivers 86, bus 43, and 
at least one of peripheral units 21-25 are IBM Model interrupt and control logic 48. Furthermore, address 
3270 terminals. It will be understood that plug-compati- and control information is generated bi-directionally 
ble units may be substituted for IBM units. along bus 52 between interrupt and control logic 46 bus 

Bus 14 has a processor 20 and a series of peripheral 45 12, and along bus 54 between interrupt and control 
units 31-35 coupled to it. Processor 20 is of a different logic 48 and bus 14. This assures synchronism between 
type than processor 16. the functioning of bus 12 and bus 14. 

In a preferred embodiment of the invention, proces- A detailed block diagram of bus interface 40 appear- 
sor 20 is a Motorola 68020 processor running under the ing between bus 12 and buses 42 and 44 is illustrated in 
UNIX operating system, and at least one of peripheral 50 FIG. 3. Line receivers 56 receive data and control infor- 
units 31-35 is a terminal unit. 

Situated between buses 12 and 14 are a bus interface 
40 associated with bus 12 and a bus interface 50 associ- 
ated with bus 14. A dual simplex path for data and 
control information is created by buses 42 and 44. A 
dual simplex path is a path wherein information is trans- 
ferred between two elements in one direction along one 
line connecting them, and simultaneously in the oppo- 
site direction along a second line connecting them. 



55 



mation from bus 42. Control information is passed to 
control logic means 64 via line 70, and data information 
is transferred through bus 69 to FIFO register stack 55. 
Bus 69 is 16-bits wide. If FIFO register stack 55 is a 
512X 18 register stack, two bits in each line of FIFO 
register 55 are ignored. Also, a predetermined number 
of lanes in FIFO register stack 55 acts as a buffer. 

FIFO register stack 55 serves as a read FIFO register 
if a READ signal is supplied on line 71 from control 
As indicated by directional arrows in FIG. 1, bus 42 60 logic means 64. Alternatively, FIFO register stack 55 



transfers data and control information from bus inter- 
face 50 to bus interface 40, while bus 44 transfers data 
and control information from bus interface 40 to bus 
interface 50. 

Bus interfaces 40 and 50 allow peripheral units 21-25 65 
to access processor 20, and they also allow peripheral 
units 31-35 to access processor 16. This functionality of 
system 10 is achieved while keeping the operation of 



serves as a write register stack if a WRITE signal is 
supplied on line 73. A WRITE signal on line 73 would 
be generated from control logic means 94 of the bus B 
interface 50 (See FIG. 4). 

FIFO register stack 55 has a status register 59 to 
indicate the level of data information in the part of 
FIFO register stack 55 which is being utilized as a 
buffer. If the buffer is full, a FULL FLAG signal indi- 
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eating this is sent along line 74 to control logic means 94 
of the bus B interface; if the buffer is half full, a HALF 
FULL signal is generated along line 76 to interrupt 
control means 62; and, if the buffer is empty an EMPTY 
signal is generated along line 75 to control logic means 

64 and interrupt control means 62. FIFO register stacks 
55 and 60 can be any of several commercially available 
parts with the required functions such as Integrated 
Device Technology Part No. IDT7201. 

Interrupt control means 62 sends control signals to 
processor 16 through bus 77 and bus logic 65. Bus logic 

65 controls and correlates information flowing from bus 
12 to other elements in the system. Board select logic 68 
controls bus logic board 65 by means of bus 67. FIFO 55 
has a data output bus 66 for sending data either to bus 12 
(through bus logic 65) or to line drivers 58. 

Referring now specifically to FIG. 4, a detailed block 
diagram of bus interface 50 appearing between bus 14 
and buses 42 and 44 is shown. The operation of the 
elements in FIG. 4 is identical to the corresponding 
elements in FIG. 3. Bus logic 95 differs slightly from 
bus logic 65, since it must interface with bus 14 which is 
of a different type than bus 12. 

Referring now specifically to FIG. 5, a fixed 16-bit 
control word 120 is illustrated. Control word 120 is 25 
used as part of a parallel data link (PDL) protocol for 
the transfer of commands and data between processor 
16 and processor 20. The PDL protocol enables up to 
128 logical devices to be logically connected in the 
system. The PDL protocol supports two kinds of trans- 
fers: data transfers and command transfers. Data trans- 
fers can be either single-byte data transfers or multi-byte 
data transfers. 

The most significant bit (MSB) 15 of control word 
120, labeled as a command bit 121, is a logical "one" 
whenever bits 0 through 7 contain a valid command 
byte 123. The command bit is a logical "zero" when bits 

121 0 through 7 contain a valid data byte 123. 

A logical unit number 122 contained in bits 8 through 
14 specifies the logical device to which the transfer is 40 
destined to go. Since the logical unit number 122 com- 
prises seven bits, the logical unit number 122 has a range 
ofOto 127. 

In a summary, bits 0 through 7 of control word 120 
contain a Command Byte (if bit 15 is set) or a Data Byte 45 
(if bit 15 is not set) for the logical device specified in bits 
8 through 14. 

As previously stated, data transfers can be either 
multi-byte or single-byte in nature. The choice of which 
type of transfer to use is determined by many system 
design considerations. One such consideration is the 
amount of data that is to be transferred. If there are four 
or fewer bytes to transfer, single-byte data transfer is 
more efficient. However, if there are five or more bytes 
to transfer, multi-byte data transfer is utilized. 

Single-byte data transfers are accomplished by plac- 
ing the data byte 123 to be transferred in bits 0 through 
7 of control word 120, placing the logical unit number 

122 in bits 8 through 14, and clearing the command bit 
121 to "zero". 

Multi-byte data transfer really begins with a com- 
mand transfer. A multi-byte data transfer block 110 is 
illustrated in FIG. 6. The first word 111 in multi-byte 
data transfer block 110 is a control word which contains 
a C_ MB- DATA command byte (see Appendix) in bits 65 
0 through 7, a logical unit number in bits 8 through 14, 
and a "one" in the command bit position. The second 
word 112 of multibyte data transfer block 110 contains 
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a count of the number of data bytes to follow. The third 
and subsequent word, collectively labeled 113, contain 
the actual data bytes to be transferred. 

The number of bytes in words 113 correspond to the 
data byte count designated in word 112. Even-num- 
bered data bytes are placed in bits 8 through 15, and 
odd-numbered data bytes are placed in bits 0 through 7. 
If the transfer contains an odd number of bytes, it may 
be advantageous to have the last of words 113 contain 
"zeros" in bits 0 through 7 to indicate that the last data 
byte has been transferred. 

By using the format specified in FIG. 6, data and 
command transfer occur between processors 16 and 20 
along a dual simplex path. While a specific format for 
control word 120 has been described, it should be ap- 
parent to those skilled in the art that variations are 
possible. For instance, the least significant bit (LSB) of 
control word 120 could be the command bit if specified 
as such, etc. 

To conclude, when the interface circuit of the present 
invention is used to interface two different types of 
computer systems, a user on either system can utilize a 
processor and/or peripheral equipment associated with 
either computer system. Efficient functioning is main- 
tained although the buses are asynchronous due to the 
status, control and interrupt functions of the interfaces. 

Data and control transfers are performed between 
different processors in the overall system according to a 
protocol which transmits information regarding 
whether a transfer represents data or a command, 
which logical unit the transfer is destined to go to, and 
the specific data or command. 

The Appendix provides detailed information regard- 
ing bus addressing, interrupt operations, status register 
operations, bus logic control functions, and command 
transfers of the present invention. Specific address 
codes have been omitted, since this will vary depending 
on the type of bus utilized. 

Through the descriptions of the Figures an improved 
multi-system interface has been disclosed. Further mod- 
ifications and improvements of the interface will occur 
to those skilled in the art. We desire it to be understood, 
therefore, that this invention is not limited to the partic- 
ular form shown, and we intend in the appended claims 
to cover all modifications which do not depart from the 
spirit and scope of this invention. 

APPENDIX 

BUS ADDRESSING: 
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READ 


WRITE 


FUNCTION 


X 




Read FIFO data 




X 


Write FIFO data 




X 


Enable interrupts 




X 


Disable interrupts 


X 




Generate Reset 




X 


Load interrupt Mask Register 




X 


Clear interrupt 4 






(other CPU reset) 




X 


Clear interrupt 3 






(write buffer full) 




X 


Clear interrupt 2 






(write buffer empty) 




X 


Clear interrupt 1 






(write buffer 4 full) 




X 


Clear interrupt 0 






(receive character available) 


X 




Read status register 






(valid lower 8 bits only) 



INTERRUPT OPERATIONS: 

10 Set by the FIFO, serving as a read FIFO 

register, when there is a character present. 10 
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APPENDIX-continued 



will be held until the CLEAR interrupt 0 command 
is issued. 

Set by the FIFO, serving as a write FIFO 
register, reaching the HALF FULL level. II will 
remain on until the CLEAR interrupt I command is 



12 Set by the FIFO, serving as a write FIFO 
register, reaching the EMPTY state. 12 will be 
held until the CLEAR interrupt 2 command is 
issued. 

13 Set by the FIFO, serving as a write FIFO 
register, reaching the FULL state. 13 will be 
held on 'until the CLEAR interrupt 3 command is 
issued. 

14 Set when the RESET level is applied to the other 
CPU. 14 will be held as long as the other 
system reset is asserted. When the other system 
reset is de-asserted, the interrupt will be 
cleared. 

STATUS REGISTER OPERATION: 

50 This is aa unlatched signal which represents the 
actual current condition of the FIFO serving as 
a read FIFO register. 

0 = The FIFO is empty. 

1 = The FIFO has an entry. 

51 A latched signal indicating that the FIFO has 
been filled to the one-half plus 1 entry level. 

I ~ The FIFO is half full. 

The bit can be reset by clearing 
interrupt 1. 

52 A latched signal indicating that the FIFO 
serving as a write FIFO register has been 
emptied. 

1 = FIFO is empty. 

This bit can be reset by clearing 
interrupt 2. 

53 Latched signal radicating the FIFO serving as a 
write FIFO register has been completely filled. 

I = FIFO is full. 

This bit can be reset by clearing 
interrupt 3. 

54 Latched signal indicating the other CPU has done 
a RESET. 

1 = System holding RESET TRUE. 
This bit can be reset by clearing 
interrupt 4. If the reset is still being 
held true, the bit will not reset. 

55 local (read) FIFO full flag (low true, not 
latched) 

56 local (read) FIFO full flag (low true, not 
latched) 

57 Summary Bit 

I = One or more of the Interrupt bits is set. 
Note that the Empty indicator (SO) is not 
latched, but the word present [NOT EMPTY] 
(10) ^latched and reflected in S7. Hence 
the interrupt status may not represent 
current status of the FIFO. 
BUS LOGIC CONTROL FUNCTIONS: 



RESET 



WRITE 
INTERRUPT 
MASK 
REGISTER 



FIFO 
READ 



FIFO 
WRITE 



ENABLE 
INTERRUPTS 



DISABLE 
INTERRUPTS 



RESET 



Reading this address retrieves a 

16 bit word from the onboard (local) FIFO 

if a word is available. 

Writing this address transfers a 16 bit 

word to the FIFO on the mating interface 

card (remote FIFO) if it is not full. If 

the FIFO is full, nothing will be written 

nor will any error be indicated! Use the 

FIFO full interrupt or the status register 

to avoid this condition. 

Writing to this location enable the OR 

of interrupt* (10-14) to be applied to 

onboard 12. Data is not significant for 

this instruction. 

Writing to this location disables the 
interrupts from the bus. Interrupt status 
is not changed, but is only de-asserted 
from the onboard bus. Data is not 
significant for this operation. 
Reading the RESET address on the logic 
board will set interrupts 10 thru 14 to all 
l's and reset both FIFO's (FIFO Data is 
LOST) . 



The Enable/Disable condition of both 
system's interrupt is not affected. A 
state signifies an ABORT with 
possible data toss. No data is returned by 
this command. 

Writing an S-bit byte to the interrupt 
mask register address allows bits to be 
sent to the logic board to enable/mask 
the individual interrupts 10-13. An "0" 
10 bit in the register will mask on the 

corresponding interrupt. A "1" bit in the 
register will mask off the corresponding 
interrupt as follows: 
BITO 10 BIT4 NOT USED 
BIT I II BITS NOT USED 
BIT2 12 BIT6 NOT USED 
BIT3 13 BIT7 NOT USED 
CLEAR Writing this address will clear 

14 interrupt 14. which would have been set by 

a hard reset or a reset command. Data is 
not significant with this command. 
CLEAR Writing to this address will clear 

13 interrupt 13 which would have been set by 

the write (remote) FIFO reaching the full 
state. This interrupt could also have been 
set by a hard or soft system reset. Data 
is not significant with this command. 
CLEAR Writing to this address will clear 

12 interrupt 12 which would have been set by 

the write (remote) FIFO reaching the 
empty state. A hard or soft reset will also 
set this interrupt true. Data is not 
significant with this command. 
CLEAR Writing to this address will clear 

II interrupt II which would have been set by 

the write (remote) FIFO reaching the half 
full state. A hard or soft reset will also 
set this interrupt true. Data is not 
significant with this command. 
CLEAR Writing to this address will clear 

10 interrupt 10 which would have been set by 

the read (local) FIFO reaching the data 
available state. A hard or soft reset will 
also set this interrupt true. Data is not 
significant with this command. 
Reading this address will return 
the logic board's status in (he 
lower 8 bits of the word. The upper 8 bits 
are not driven by the board and will 
probably be FF hex. 
COMMAND TRANSFERS: 
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REGISTER 
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C_RESET This command is used to reset the PDL 

interface. It may be issued by either side 
of the interface. 
C_ONLINE This command is used to signal device 

availability. It may be issued by either 
side of the interface. 
C_OFFLINE This command is used whenever a device has 

become unavailable. 
C_SACT This command is used whenever a device 
which was temporarily unavailable (see 
C_ SIN ACT. below) has returned to ser- 
vice. C SACT may be issued by either side of 

the 

interface. 

C_SINACT This command is used whenever a device 

becomes temporarily unavailable, usually 
due to the device switching to an alternate 
session. C_SINACT may be issued by 
either side of the interface. 
C_SEND This command (in conjunction with 

C__STOP) provides device level flow con- 
trol. C_SEND may be issued by either 
side of the interface. 
C_STOP This command (in conjunction with 

C SEND) provides device level flow con- 
trol- C_STOP may be issued by 
. either side of the interface. 
C_MB_DATA This command signifies the start of a 

Multibyte Data Transfer. 
C_FT_START This command indicates the beginning of 
File Transfer Mode. 
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APPENDIX-continued 



C_FT_STOP This command terminates File Transfer Mode. 
C FT RESEND This command is used to request 

retransmission of the last File Transfer 

data block. 

C_ALARM This command is used to indicate that data 

is present for the logical unit but the 
logical unit is presently inactive (see 
C_SINACT, above). 

C_LU_DSP This command is used to configure the 

logical unit as an ASCII display device. 

C_ LU_PRT This command is used to configure the 

logical unit as an ASCII print device. 

C_LU_DECONF This command is used to deconfigure 
ASCII display and printer devices. 

C_MB_ACK This command is used to acknowledge the 
receipt of a Multi-byte Data Transfer 
command. It may be sent by either side of 
the interface when it is determined that 
enough buffer space exists to receive 
another multi-byte data transfer. 

C_NOP The C_NOP command is used to send a 

dummy command. It may be sent by either 
side of the interface; 

C_CMD_REJ The C_CMD_REJ command is used 
whenever the last command received for 
device is logically incorrect 
(eg: sending C_SEND when the logical 
unit is not blocked* etc.) It may be sent 
by either side of the interface. 

C_LU_R£SET The C_LU_ RESET command resets 
a specific port. 

C BREAK The C BREAK command signals the 

coordinated processor to emulate the pro- 
cosing required to break the transmission. 
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We claim: 

1. A multi-processor, multi-bus system comprising a 
first processor coupled to a first bus, a second processor 
of a type different from said first processor, said second 
processor being coupled to a second bus, said second 
bus of a type different from said first bus, the improve- 
ment wherein said system comprises: 
bus interface means for coupling said first bus to said 
second bus, said bus interface means comprising: 
a first-first-in first-out (FIFO) register stack for 
receiving data from said second bus and for 
transmitting data to said first bus; 
a second first-in-first-out (FIFO) register stack for 
receiving data from said first bus and for trans- 
mitting data to said second bus; 
control logic means coupled to said first and sec- 
ond FIFO register stacks and to said first and 
second buses for receiving control information 
from said first and second buses and for control- 50 
ling the operation of said FIFO register stacks in 
response to said control information, said control 
logic means comprising interrupt logic means 
and status logic means; 
first receiver means coupled to said first FIFO 55 

register stack; 
first transmitter means coupled to said first bus for 
receiving first data and control information from 
said first bus and for transmitting said first data 
and control information to said second FIFO 60 
register stack; 
second receiver means coupled to said second 

FIFO register stack; and 
second transmitter means coupled to said second 
bus for receiving second data and control infor- 
mation from said second bus and for transmitting 
said second data and control information to said 
first FIFO register stack; 



65 



wherein said first receiver means is for receiving 
said second data and control information from 
said second transmitter means and said second 
receiver means is for receiving said first data and 
control information from said first transmitter 
means. 

2. The system recited in claim 1 and further compris- 
ing: 

a first plurality of peripheral units coupled to said first 
bus. 

3. The system recited in claim 1 and further compris- 
ing: 

a second plurality of peripheral units coupled to said 
second bus. 

4. In a multi-processor, multi-bus system comprising a 
first processor and a controller coupled to a first bus, 
said controller also being coupled to a first plurality of 
peripheral units; a second processor of a type different 
from said first processor, a second plurality of periph- 
eral units, said second processor and said second plural- 
ity of peripheral units being coupled to a second bus, 
said second bus of a type different from said first bus; 
the improvement wherein said system comprises: 

first bus interface means for coupling said first plural- 
ity of peripheral units to said second processor, said 
first bus interface means being coupled between 
said first and second buses and comprising: 
a first first-in-first-out (FIFO) register stack for 
receiving data from said second bus and for 
transmitting data to said first bus; 
a first control logic means coupled to said first 
FIFO register stack for receiving first control 
information from said second bus and for con- 
trolling the operation of said first FIFO register 
stack in response to said first control informa- 
tion; 

first receiver means coupled to said second bus for 
receiving data and control information from said 
second bus; 

* first transmitter means coupled to said second bus 
for transmitting data and control information to 
said second bus; and 
first interrupt means coupled to said first FIFO 
register stack and to said first receiver means for 
generating an interrupt signal to said second 
processor when said first FIFO register stack has 
been filled to a predetermined level; and 
second bus interface means for coupling said second 
plurality of peripheral units to said first processor, 
said second bus interface means being coupled 
between said first and second buses and compris- 
ing: 

a second first-in-first-out (FIFO) register stack for 
receiving data from said first bus and for trans- 
mitting data to said second bus; 

second control logic means coupled to said second 
FIFO register stack for receiving second control 
information from said second bus and for con- 
trolling the operation of said second FIFO regis- 
ter stack in response to said second control infor- 
mation; 

second receiver means coupled to said first bus for 
receiving data and control information from said 
first bus; 

second transmitter means coupled to said first bus 
for transmitting data and control information to 
said first bus; and 
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second interrupt means coupled to said second and said S bit portion indicates the logical unit 

FIFO register stack and to said second receiver .^ ucstin 8 t™*^ 

, • • . utilizing a 16-bit count word following said control 

means for generating an interrupt signal to said wQr * for mdicating thc numbcr of ^ bytes 

first processor when said second FIFO register 5 whicn foUow ^ that ^ to be transferred; and 

stack has been filled to a predetermined level. storing said data bytes in a plurality of 16-bit data 

5. In a multi-processor system comprising two pro- words following said count word, 

cessors each coupled to a different type of system bus, a 6- The method recited in claim 5, wherein when T is 

method of interfacing between said two processors, said * logical "one" it indicates that said R-bit portion con- 

- , . . 10 tains a data command byte and when T is a logical 

method compnsmg: „ zero „ ^ Scales that said R-bit portion contains a data 

using an N-bit control word to preface data control byte 

information to be passed from one processor to the 7. The method recited in claim 5, wherein even-num- 

other, said control word comprising an R-bit infor- bered bytes are placed in most significant bits 8*15 of 

mation portion, an S-bit destination portion, and a IS said data words and odd-numbered bytes are placed in 

T-bit data type portion for indicating whether said least sipifkant bits 0-7 of said data word. 

R-bit portion contains data or control information, 8 * ^ rec,tc * m ^m 7 wherein if said 

™™ „ J;\ , rl . , J count word indicates an odd number of data bytes to be 

wherein N is 16, R is 8, S is 7, and T is 1 and transrerred , ^ ^ one D f said plurality of data words 

wherein said T-bit portion indicates whether the 20 ^ i ogical "zeros" in bits 0-7 in order to indicate that 

R-bit portion contains control information, the the last data byte has been transferred. 

R-bit portion indicates a multi-byte data transfer, * • * * * 
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